#include<iostream>

using namespace std;

const int N = 1e5 + 10;

int n , m;
int ne[N] , h , pre[N];
bool st[N];
int main()
{
    cin >> n;
    pre[1] = h;
    ne[h] = 1;
    for(int i = 2;i <= n;i ++)
    {
        int k, p;
        cin >> k >> p;
        //i放在k的左边 h      k
        //               i
        if(p == 0)  
        {
            ne[i] = k;
            pre[i] = pre[k];
            ne[pre[k]] = i;
            pre[k] = i;
        }
        //i 放置在k 的右边 k     h
        //                  i
        else
        {
            pre[i] = k;
            ne[i] = ne[k];
            pre[ne[k]] = i;
            ne[k] = i;
        }
    }
    int m;cin >> m;
    while(m--)
    {
        int x; cin >> x;
        if(st[x]) continue;

        ne[pre[x]] = ne[x];
        pre[ne[x]] = pre[x];
        st[x] = true;
    }

    for(int i = ne[h];i;i = ne[i])
    {
        cout << i << " ";
    }
    return 0;
}